Python爬取m3u8视频(多线程) 您所在的位置:网站首页 python 多线程下载视频 Python爬取m3u8视频(多线程)

Python爬取m3u8视频(多线程)

2023-07-16 13:39| 来源: 网络整理| 查看: 265

1.前言

 

爬取视频的时候发现,现在的视频都是经过加密(m3u8),不再是mp4或者avi链接直接在网页显示,都是经过加密形成ts文件分段进行播放。

今天就教大家如果通过python爬取下载m3u8加密视频。

2.分析网页1.电影视频来源http://www.caisetv.com/

Python爬取m3u8视频(多线程)- OK好用,代码在文章尾_python

2.分析m3u8加密目录http://www.caisetv.com/dongzuopian/chaidanzhuanjia/0-1.html

Python爬取m3u8视频(多线程)- OK好用,代码在文章尾_python_02

 

在视频播放的页面,通过F12可以查看网络数据包

https://xigua-cdn.haima-zuida.com/20210219/19948_fcbc225a/1000k/hls/index.m3u8

Python爬取m3u8视频(多线程)- OK好用,代码在文章尾_python_03

 

这里的ts就电影的加密分段视频

https://xigua-cdn.haima-zuida.com/20210219/19948_fcbc225a/1000k/hls/

上面的m3u8链接掉index.m3u8后,在拼上075a34cccdd000000.ts等ts名称就是分段视频的链接

如下所示:

https://xigua-cdn.haima-zuida.com/20210219/19948_fcbc225a/1000k/hls/075a34cccdd000000.ts

通过浏览器把这个分段视频下载后打开:

 

Python爬取m3u8视频(多线程)- OK好用,代码在文章尾_python_04

 

所以只要把所有的ts下载并合并就是完整的电影视频!!!

3.下载ts1.下载ts分段视频

刚刚已经把ts的所有名称下载下来了

 

Python爬取m3u8视频(多线程)- OK好用,代码在文章尾_bc_05

 

接下来通过python代码去读取这个文件,提取出名称,拼接链接后下载保存到一个文件夹里!

headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.3; Win64; x64; rv:84.0) Gecko/20100101 Firefox/84.0',}

###下载ts文件def download(url,name): r = requests.get(url, headers=headers) with open(name+"", "wb") as code: code.write(r.content)

with open("index.m3u8","r") as f: ts_list = f.readlines()

#去掉前面没用的信息ts_list = ts_list[5:]urlheader="https://xigua-cdn.haima-zuida.com/20210219/19948_fcbc225a/1000k/hls/"count = 0for i in ts_list: if "#" not in i: i = i.replace("\n","") download(urlheader+""+i,"cdzj2/"+str(count)+".ts") count = count+1 print(count)

Python爬取m3u8视频(多线程)- OK好用,代码在文章尾_python_06

 

这样就可以把ts文件全部下载下来,但是一个一个下载很慢,下面通过多线程下载,提升下载速度!!!

2.多线程下载ts视频for i in ts_list: if "#" not in i: i = i.replace("\n","") n = i[-7:] threading.Thread(target=download, args=(urlheader+""+i,"cdzj2/"+str(n),)).start() #download(urlheader+""+i,"cdzj2/"+str(count)+".ts")

Python爬取m3u8视频(多线程)- OK好用,代码在文章尾_bc_07

 

通过多线程很快就可以将这些ts文件下载到本地!!!

4.合并tscmd合并文件copy /b *.ts new.mp4

通过这个命令(cmd终端中运行),在含有ts文件的文件夹中就可以将ts文件合并(按名称顺序进行排列合并),并保存成new.mp4

 

Python爬取m3u8视频(多线程)- OK好用,代码在文章尾_python_08

5.总结

1.分析m3u8加密文件2.python下载ts文件3.cmd合并ts保存成mp4格式

 6.我的代码(全)1 # -*- coding:utf-8 -*- 2 import os 3 import requests 4 import shutil 5 import time 6 import threading 7 8 9 def download(url, name): 10 """下载ts文件""" 11 12 headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.3; Win64; x64; rv:84.0) Gecko/20100101 Firefox/84.0', } 13 r = requests.get(url, headers=headers) 14 with open(name + "", "wb") as code: 15 code.write(r.content) 16 17 18 def m3u8_download_multi_thread(m3u8, mp4, thread_max=10): 19 ts_in = mp4 + os.sep + "ts" 20 if not os.path.exists(ts_in): 21 os.makedirs(ts_in) # mkdir -p ./a/b/c 22 23 urlheader = os.path.dirname(m3u8) 24 m3u8_local = mp4 + "/index.m3u8" 25 26 download(m3u8, m3u8_local) 27 28 with open(m3u8_local, "r") as f: 29 ts_list = f.readlines() 30 31 # 多线程 32 line = 0 33 count = 0 34 for i in ts_list: 35 # if count >= 10: 36 # break 37 line = line + 1 38 while thread_max


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有